home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
SGI Freeware 1999 August
/
SGI Freeware 1999 August.iso
/
dist
/
fw_xemacs.idb
/
usr
/
freeware
/
lib
/
xemacs-20.4
/
info
/
xemacs.info-10.z
/
xemacs.info-10
Encoding:
Amiga
Atari
Commodore
DOS
FM Towns/JPY
Macintosh
Macintosh JP
Macintosh to JP
NeXTSTEP
RISC OS/Acorn
Shift JIS
UTF-8
Wrap
GNU Info File
|
1998-05-21
|
46.5 KB
|
1,093 lines
This is Info file ../../info/xemacs.info, produced by Makeinfo version
1.68 from the input file xemacs.texi.
This file documents the XEmacs editor.
Copyright (C) 1985, 1986, 1988 Richard M. Stallman. Copyright (C)
1991, 1992, 1993, 1994 Lucid, Inc. Copyright (C) 1993, 1994 Sun
Microsystems, Inc. Copyright (C) 1995 Amdahl Corporation.
Permission is granted to make and distribute verbatim copies of this
manual provided the copyright notice and this permission notice are
preserved on all copies.
Permission is granted to copy and distribute modified versions of
this manual under the conditions for verbatim copying, provided also
that the sections entitled "The GNU Manifesto", "Distribution" and "GNU
General Public License" are included exactly as in the original, and
provided that the entire resulting derived work is distributed under the
terms of a permission notice identical to this one.
Permission is granted to copy and distribute translations of this
manual into another language, under the above conditions for modified
versions, except that the sections entitled "The GNU Manifesto",
"Distribution" and "GNU General Public License" may be included in a
translation approved by the author instead of in the original English.
File: xemacs.info, Node: Lists, Next: Defuns, Prev: Program Modes, Up: Programs
Lists and Sexps
===============
By convention, Emacs keys for dealing with balanced expressions are
usually `Control-Meta-' characters. They tend to be analogous in
function to their `Control-' and `Meta-' equivalents. These commands
are usually thought of as pertaining to expressions in programming
languages, but can be useful with any language in which some sort of
parentheses exist (including English).
The commands fall into two classes. Some commands deal only with
"lists" (parenthetical groupings). They see nothing except
parentheses, brackets, braces (depending on what must balance in the
language you are working with), and escape characters that might be used
to quote those.
The other commands deal with expressions or "sexps". The word `sexp'
is derived from "s-expression", the term for a symbolic expression in
Lisp. In Emacs, the notion of `sexp' is not limited to Lisp. It
refers to an expression in the language your program is written in.
Each programming language has its own major mode, which customizes the
syntax tables so that expressions in that language count as sexps.
Sexps typically include symbols, numbers, and string constants, as
well as anything contained in parentheses, brackets, or braces.
In languages that use prefix and infix operators, such as C, it is
not possible for all expressions to be sexps. For example, C mode does
not recognize `foo + bar' as an sexp, even though it is a C expression;
it recognizes `foo' as one sexp and `bar' as another, with the `+' as
punctuation between them. This is a fundamental ambiguity: both `foo +
bar' and `foo' are legitimate choices for the sexp to move over if
point is at the `f'. Note that `(foo + bar)' is a sexp in C mode.
Some languages have obscure forms of syntax for expressions that
nobody has bothered to make Emacs understand properly.
`C-M-f'
Move forward over an sexp (`forward-sexp').
`C-M-b'
Move backward over an sexp (`backward-sexp').
`C-M-k'
Kill sexp forward (`kill-sexp').
`C-M-u'
Move up and backward in list structure (`backward-up-list').
`C-M-d'
Move down and forward in list structure (`down-list').
`C-M-n'
Move forward over a list (`forward-list').
`C-M-p'
Move backward over a list (`backward-list').
`C-M-t'
Transpose expressions (`transpose-sexps').
`C-M-@'
Put mark after following expression (`mark-sexp').
To move forward over an sexp, use `C-M-f' (`forward-sexp'). If the
first significant character after point is an opening delimiter (`(' in
Lisp; `(', `[', or `{' in C), `C-M-f' moves past the matching closing
delimiter. If the character begins a symbol, string, or number,
`C-M-f' moves over that. If the character after point is a closing
delimiter, `C-M-f' just moves past it. (This last is not really moving
across an sexp; it is an exception which is included in the definition
of `C-M-f' because it is as useful a behavior as anyone can think of
for that situation.)
The command `C-M-b' (`backward-sexp') moves backward over a sexp.
The detailed rules are like those above for `C-M-f', but with
directions reversed. If there are any prefix characters (single quote,
back quote, and comma, in Lisp) preceding the sexp, `C-M-b' moves back
over them as well.
`C-M-f' or `C-M-b' with an argument repeats that operation the
specified number of times; with a negative argument, it moves in the
opposite direction.
In languages such as C where the comment-terminator can be
recognized, the sexp commands move across comments as if they were
whitespace. In Lisp and other languages where comments run until the
end of a line, it is very difficult to ignore comments when parsing
backwards; therefore, in such languages the sexp commands treat the
text of comments as if it were code.
Killing an sexp at a time can be done with `C-M-k' (`kill-sexp').
`C-M-k' kills the characters that `C-M-f' would move over.
The "list commands", `C-M-n' (`forward-list') and `C-M-p'
(`backward-list'), move over lists like the sexp commands but skip over
any number of other kinds of sexps (symbols, strings, etc). In some
situations, these commands are useful because they usually ignore
comments, since the comments usually do not contain any lists.
`C-M-n' and `C-M-p' stay at the same level in parentheses, when that
is possible. To move up one (or N) levels, use `C-M-u'
(`backward-up-list'). `C-M-u' moves backward up past one unmatched
opening delimiter. A positive argument serves as a repeat count; a
negative argument reverses direction of motion and also requests
repetition, so it moves forward and up one or more levels.
To move down in list structure, use `C-M-d' (`down-list'). In Lisp
mode, where `(' is the only opening delimiter, this is nearly the same
as searching for a `('. An argument specifies the number of levels of
parentheses to go down.
`C-M-t' (`transpose-sexps') drags the previous sexp across the next
one. An argument serves as a repeat count, and a negative argument
drags backwards (thus canceling out the effect of `C-M-t' with a
positive argument). An argument of zero, rather than doing nothing,
transposes the sexps ending after point and the mark.
To make the region be the next sexp in the buffer, use `C-M-@'
(`mark-sexp') which sets the mark at the same place that `C-M-f' would
move to. `C-M-@' takes arguments like `C-M-f'. In particular, a
negative argument is useful for putting the mark at the beginning of
the previous sexp.
The list and sexp commands' understanding of syntax is completely
controlled by the syntax table. Any character can, for example, be
declared to be an opening delimiter and act like an open parenthesis.
*Note Syntax::.
File: xemacs.info, Node: Defuns, Next: Grinding, Prev: Lists, Up: Programs
Defuns
======
In Emacs, a parenthetical grouping at the top level in the buffer is
called a "defun". The name derives from the fact that most top-level
lists in Lisp are instances of the special form `defun', but Emacs
calls any top-level parenthetical grouping counts a defun regardless of
its contents or the programming language. For example, in C, the body
of a function definition is a defun.
`C-M-a'
Move to beginning of current or preceding defun
(`beginning-of-defun').
`C-M-e'
Move to end of current or following defun (`end-of-defun').
`C-M-h'
Put region around whole current or following defun (`mark-defun').
The commands to move to the beginning and end of the current defun
are `C-M-a' (`beginning-of-defun') and `C-M-e' (`end-of-defun').
To operate on the current defun, use `C-M-h' (`mark-defun') which
puts point at the beginning and the mark at the end of the current or
next defun. This is the easiest way to prepare for moving the defun to
a different place. In C mode, `C-M-h' runs the function
`mark-c-function', which is almost the same as `mark-defun', but which
backs up over the argument declarations, function name, and returned
data type so that the entire C function is inside the region.
To compile and evaluate the current defun, use `M-x compile-defun'.
This function prints the results in the minibuffer. If you include an
argument, it inserts the value in the current buffer after the defun.
Emacs assumes that any open-parenthesis found in the leftmost column
is the start of a defun. Therefore, never put an open-parenthesis at
the left margin in a Lisp file unless it is the start of a top level
list. Never put an open-brace or other opening delimiter at the
beginning of a line of C code unless it starts the body of a function.
The most likely problem case is when you want an opening delimiter at
the start of a line inside a string. To avoid trouble, put an escape
character (`\' in C and Emacs Lisp, `/' in some other Lisp dialects)
before the opening delimiter. It will not affect the contents of the
string.
The original Emacs found defuns by moving upward a level of
parentheses until there were no more levels to go up. This required
scanning back to the beginning of the buffer for every function. To
speed this up, Emacs was changed to assume that any `(' (or other
character assigned the syntactic class of opening-delimiter) at the
left margin is the start of a defun. This heuristic is nearly always
right; however, it mandates the convention described above.
File: xemacs.info, Node: Grinding, Next: Matching, Prev: Defuns, Up: Programs
Indentation for Programs
========================
The best way to keep a program properly indented ("ground") is to
use Emacs to re-indent it as you change the program. Emacs has commands
to indent properly either a single line, a specified number of lines, or
all of the lines inside a single parenthetical grouping.
* Menu:
* Basic Indent::
* Multi-line Indent:: Commands to reindent many lines at once.
* Lisp Indent:: Specifying how each Lisp function should be indented.
* C Indent:: Choosing an indentation style for C code.
File: xemacs.info, Node: Basic Indent, Next: Multi-line Indent, Prev: Grinding, Up: Grinding
Basic Program Indentation Commands
----------------------------------
`<TAB>'
Adjust indentation of current line.
`<LFD>'
Equivalent to <RET> followed by <TAB> (`newline-and-indent').
The basic indentation command is <TAB>, which gives the current line
the correct indentation as determined from the previous lines. The
function that <TAB> runs depends on the major mode; it is
`lisp-indent-line' in Lisp mode, `c-indent-line' in C mode, etc. These
functions understand different syntaxes for different languages, but
they all do about the same thing. <TAB> in any programming language
major mode inserts or deletes whitespace at the beginning of the
current line, independent of where point is in the line. If point is
inside the whitespace at the beginning of the line, <TAB> leaves it at
the end of that whitespace; otherwise, <TAB> leaves point fixed with
respect to the characters around it.
Use `C-q <TAB>' to insert a tab at point.
When entering a large amount of new code, use <LFD>
(`newline-and-indent'), which is equivalent to a <RET> followed by a
<TAB>. <LFD> creates a blank line, then gives it the appropriate
indentation.
<TAB> indents the second and following lines of the body of a
parenthetical grouping each under the preceding one; therefore, if you
alter one line's indentation to be nonstandard, the lines below tend to
follow it. This is the right behavior in cases where the standard
result of <TAB> does not look good.
Remember that Emacs assumes that an open-parenthesis, open-brace, or
other opening delimiter at the left margin (including the indentation
routines) is the start of a function. You should therefore never have
an opening delimiter in column zero that is not the beginning of a
function, not even inside a string. This restriction is vital for
making the indentation commands fast. *Note Defuns::, for more
information on this behavior.
File: xemacs.info, Node: Multi-line Indent, Next: Lisp Indent, Prev: Basic Indent, Up: Grinding
Indenting Several Lines
-----------------------
Several commands are available to re-indent several lines of code
which have been altered or moved to a different level in a list
structure.
`C-M-q'
Re-indent all the lines within one list (`indent-sexp').
`C-u <TAB>'
Shift an entire list rigidly sideways so that its first line is
properly indented.
`C-M-\'
Re-indent all lines in the region (`indent-region').
To re-indent the contents of a single list, position point before the
beginning of it and type `C-M-q'. This key is bound to `indent-sexp' in
Lisp mode, `indent-c-exp' in C mode, and bound to other suitable
functions in other modes. The indentation of the line the sexp starts
on is not changed; therefore, only the relative indentation within the
list, and not its position, is changed. To correct the position as
well, type a <TAB> before `C-M-q'.
If the relative indentation within a list is correct but the
indentation of its beginning is not, go to the line on which the list
begins and type `C-u <TAB>'. When you give <TAB> a numeric argument,
it moves all the lines in the group, starting on the current line,
sideways the same amount that the current line moves. The command does
not move lines that start inside strings, or C preprocessor lines when
in C mode.
Another way to specify a range to be re-indented is with point and
mark. The command `C-M-\' (`indent-region') applies <TAB> to every
line whose first character is between point and mark.
File: xemacs.info, Node: Lisp Indent, Next: C Indent, Prev: Multi-line Indent, Up: Grinding
Customizing Lisp Indentation
----------------------------
The indentation pattern for a Lisp expression can depend on the
function called by the expression. For each Lisp function, you can
choose among several predefined patterns of indentation, or define an
arbitrary one with a Lisp program.
The standard pattern of indentation is as follows: the second line
of the expression is indented under the first argument, if that is on
the same line as the beginning of the expression; otherwise, the second
line is indented underneath the function name. Each following line is
indented under the previous line whose nesting depth is the same.
If the variable `lisp-indent-offset' is non-`nil', it overrides the
usual indentation pattern for the second line of an expression, so that
such lines are always indented `lisp-indent-offset' more columns than
the containing list.
Certain functions override the standard pattern. Functions whose
names start with `def' always indent the second line by
`lisp-body-indention' extra columns beyond the open-parenthesis
starting the expression.
Individual functions can override the standard pattern in various
ways, according to the `lisp-indent-function' property of the function
name. (Note: `lisp-indent-function' was formerly called
`lisp-indent-hook'). There are four possibilities for this property:
`nil'
This is the same as no property; the standard indentation pattern
is used.
`defun'
The pattern used for function names that start with `def' is used
for this function also.
a number, NUMBER
The first NUMBER arguments of the function are "distinguished"
arguments; the rest are considered the "body" of the expression.
A line in the expression is indented according to whether the
first argument on it is distinguished or not. If the argument is
part of the body, the line is indented `lisp-body-indent' more
columns than the open-parenthesis starting the containing
expression. If the argument is distinguished and is either the
first or second argument, it is indented twice that many extra
columns. If the argument is distinguished and not the first or
second argument, the standard pattern is followed for that line.
a symbol, SYMBOL
SYMBOL should be a function name; that function is called to
calculate the indentation of a line within this expression. The
function receives two arguments:
STATE
The value returned by `parse-partial-sexp' (a Lisp primitive
for indentation and nesting computation) when it parses up to
the beginning of this line.
POS
The position at which the line being indented begins.
It should return either a number, which is the number of columns of
indentation for that line, or a list whose first element is such a
number. The difference between returning a number and returning a
list is that a number says that all following lines at the same
nesting level should be indented just like this one; a list says
that following lines might call for different indentations. This
makes a difference when the indentation is computed by `C-M-q'; if
the value is a number, `C-M-q' need not recalculate indentation
for the following lines until the end of the list.
File: xemacs.info, Node: C Indent, Prev: Lisp Indent, Up: Grinding
Customizing C Indentation
-------------------------
Two variables control which commands perform C indentation and when.
If `c-auto-newline' is non-`nil', newlines are inserted both before
and after braces that you insert and after colons and semicolons.
Correct C indentation is done on all the lines that are made this way.
If `c-tab-always-indent' is non-`nil', the <TAB> command in C mode
does indentation only if point is at the left margin or within the
line's indentation. If there is non-whitespace to the left of point,
<TAB> just inserts a tab character in the buffer. Normally, this
variable is `nil', and <TAB> always reindents the current line.
C does not have anything analogous to particular function names for
which special forms of indentation are desirable. However, it has a
different need for customization facilities: many different styles of C
indentation are in common use.
There are six variables you can set to control the style that Emacs C
mode will use.
`c-indent-level'
Indentation of C statements within surrounding block. The
surrounding block's indentation is the indentation of the line on
which the open-brace appears.
`c-continued-statement-offset'
Extra indentation given to a substatement, such as the then-clause
of an `if' or body of a `while'.
`c-brace-offset'
Extra indentation for lines that start with an open brace.
`c-brace-imaginary-offset'
An open brace following other text is treated as if it were this
far to the right of the start of its line.
`c-argdecl-indent'
Indentation level of declarations of C function arguments.
`c-label-offset'
Extra indentation for a line that is a label, case, or default.
The variable `c-indent-level' controls the indentation for C
statements with respect to the surrounding block. In the example:
{
foo ();
the difference in indentation between the lines is `c-indent-level'.
Its standard value is 2.
If the open-brace beginning the compound statement is not at the
beginning of its line, the `c-indent-level' is added to the indentation
of the line, not the column of the open-brace. For example,
if (losing) {
do_this ();
One popular indentation style is that which results from setting
`c-indent-level' to 8 and putting open-braces at the end of a line in
this way. Another popular style prefers to put the open-brace on a
separate line.
In fact, the value of the variable `c-brace-imaginary-offset' is
also added to the indentation of such a statement. Normally this
variable is zero. Think of this variable as the imaginary position of
the open brace, relative to the first non-blank character on the line.
By setting the variable to 4 and `c-indent-level' to 0, you can get
this style:
if (x == y) {
do_it ();
}
When `c-indent-level' is zero, the statements inside most braces
line up exactly under the open brace. An exception are braces in column
zero, like those surrounding a function's body. The statements inside
those braces are not placed at column zero. Instead, `c-brace-offset'
and `c-continued-statement-offset' (see below) are added to produce a
typical offset between brace levels, and the statements are indented
that far.
`c-continued-statement-offset' controls the extra indentation for a
line that starts within a statement (but not within parentheses or
brackets). These lines are usually statements inside other statements,
like the then-clauses of `if' statements and the bodies of `while'
statements. The `c-continued-statement-offset' parameter determines
the difference in indentation between the two lines in:
if (x == y)
do_it ();
The default value for `c-continued-statement-offset' is 2. Some
popular indentation styles correspond to a value of zero for
`c-continued-statement-offset'.
`c-brace-offset' is the extra indentation given to a line that
starts with an open-brace. Its standard value is zero; compare:
if (x == y)
{
with:
if (x == y)
do_it ();
If you set `c-brace-offset' to 4, the first example becomes:
if (x == y)
{
`c-argdecl-indent' controls the indentation of declarations of the
arguments of a C function. It is absolute: argument declarations
receive exactly `c-argdecl-indent' spaces. The standard value is 5 and
results in code like this:
char *
index (string, char)
char *string;
int char;
`c-label-offset' is the extra indentation given to a line that
contains a label, a case statement, or a `default:' statement. Its
standard value is -2 and results in code like this:
switch (c)
{
case 'x':
If `c-label-offset' were zero, the same code would be indented as:
switch (c)
{
case 'x':
This example assumes that the other variables above also have their
default values.
Using the indentation style produced by the default settings of the
variables just discussed and putting open braces on separate lines
produces clear and readable files. For an example, look at any of the C
source files of XEmacs.
File: xemacs.info, Node: Matching, Next: Comments, Prev: Grinding, Up: Programs
Automatic Display of Matching Parentheses
=========================================
The Emacs parenthesis-matching feature shows you automatically how
parentheses match in the text. Whenever a self-inserting character that
is a closing delimiter is typed, the cursor moves momentarily to the
location of the matching opening delimiter, provided that is visible on
the screen. If it is not on the screen, some text starting with that
opening delimiter is displayed in the echo area. Either way, you see
the grouping you are closing off.
In Lisp, automatic matching applies only to parentheses. In C, it
also applies to braces and brackets. Emacs knows which characters to
regard as matching delimiters based on the syntax table set by the major
mode. *Note Syntax::.
If the opening delimiter and closing delimiter are mismatched--as in
`[x)'--the echo area displays a warning message. The correct matches
are specified in the syntax table.
Two variables control parenthesis matching displays.
`blink-matching-paren' turns the feature on or off. The default is `t'
(match display is on); `nil' turns it off.
`blink-matching-paren-distance' specifies how many characters back
Emacs searches to find a matching opening delimiter. If the match is
not found in the specified region, scanning stops, and nothing is
displayed. This prevents wasting lots of time scanning when there is no
match. The default is 4000.
File: xemacs.info, Node: Comments, Next: Balanced Editing, Prev: Matching, Up: Programs
Manipulating Comments
=====================
The comment commands insert, kill and align comments.
`M-;'
Insert or align comment (`indent-for-comment').
`C-x ;'
Set comment column (`set-comment-column').
`C-u - C-x ;'
Kill comment on current line (`kill-comment').
`M-<LFD>'
Like <RET> followed by inserting and aligning a comment
(`indent-new-comment-line').
The command that creates a comment is `Meta-;'
(`indent-for-comment'). If there is no comment already on the line, a
new comment is created and aligned at a specific column called the
"comment column". Emacs creates the comment by inserting the string at
the value of `comment-start'; see below. Point is left after that
string. If the text of the line extends past the comment column,
indentation is done to a suitable boundary (usually, at least one space
is inserted). If the major mode has specified a string to terminate
comments, that string is inserted after point, to keep the syntax valid.
You can also use `Meta-;' to align an existing comment. If a line
already contains the string that starts comments, `M-;' just moves
point after it and re-indents it to the conventional place. Exception:
comments starting in column 0 are not moved.
Some major modes have special rules for indenting certain kinds of
comments in certain contexts. For example, in Lisp code, comments which
start with two semicolons are indented as if they were lines of code,
instead of at the comment column. Comments which start with three
semicolons are supposed to start at the left margin. Emacs understands
these conventions by indenting a double-semicolon comment using <TAB>
and by not changing the indentation of a triple-semicolon comment at
all.
;; This function is just an example.
;;; Here either two or three semicolons are appropriate.
(defun foo (x)
;;; And now, the first part of the function:
;; The following line adds one.
(1+ x)) ; This line adds one.
In C code, a comment preceded on its line by nothing but whitespace
is indented like a line of code.
Even when an existing comment is properly aligned, `M-;' is still
useful for moving directly to the start of the comment.
`C-u - C-x ;' (`kill-comment') kills the comment on the current
line, if there is one. The indentation before the start of the comment
is killed as well. If there does not appear to be a comment in the
line, nothing happens. To reinsert the comment on another line, move
to the end of that line, type first `C-y', and then `M-;' to realign
the comment. Note that `C-u - C-x ;' is not a distinct key; it is `C-x
;' (`set-comment-column') with a negative argument. That command is
programmed to call `kill-comment' when called with a negative argument.
However, `kill-comment' is a valid command which you could bind
directly to a key if you wanted to.
Multiple Lines of Comments
--------------------------
If you are typing a comment and want to continue it on another line,
use the command `Meta-<LFD>' (`indent-new-comment-line'), which
terminates the comment you are typing, creates a new blank line
afterward, and begins a new comment indented under the old one. If
Auto Fill mode is on and you go past the fill column while typing, the
comment is continued in just this fashion. If point is not at the end
of the line when you type `M-<LFD>', the text on the rest of the line
becomes part of the new comment line.
Options Controlling Comments
----------------------------
The comment column is stored in the variable `comment-column'. You
can explicitly set it to a number. Alternatively, the command `C-x ;'
(`set-comment-column') sets the comment column to the column point is
at. `C-u C-x ;' sets the comment column to match the last comment
before point in the buffer, and then calls `Meta-;' to align the
current line's comment under the previous one. Note that `C-u - C-x ;'
runs the function `kill-comment' as described above.
`comment-column' is a per-buffer variable; altering the variable
affects only the current buffer. You can also change the default value.
*Note Locals::. Many major modes initialize this variable for the
current buffer.
The comment commands recognize comments based on the regular
expression that is the value of the variable `comment-start-skip'.
This regexp should not match the null string. It may match more than
the comment starting delimiter in the strictest sense of the word; for
example, in C mode the value of the variable is `"/\\*+ *"', which
matches extra stars and spaces after the `/*' itself. (Note that `\\'
is needed in Lisp syntax to include a `\' in the string, which is needed
to deny the first star its special meaning in regexp syntax. *Note
Regexps::.)
When a comment command makes a new comment, it inserts the value of
`comment-start' to begin it. The value of `comment-end' is inserted
after point and will follow the text you will insert into the comment.
In C mode, `comment-start' has the value `"/* "' and `comment-end' has
the value `" */"'.
`comment-multi-line' controls how `M-<LFD>'
(`indent-new-comment-line') behaves when used inside a comment. If
`comment-multi-line' is `nil', as it normally is, then `M-<LFD>'
terminates the comment on the starting line and starts a new comment on
the new following line. If `comment-multi-line' is not `nil', then
`M-<LFD>' sets up the new following line as part of the same comment
that was found on the starting line. This is done by not inserting a
terminator on the old line and not inserting a starter on the new line.
In languages where multi-line comments are legal, the value you choose
for this variable is a matter of taste.
The variable `comment-indent-hook' should contain a function that is
called to compute the indentation for a newly inserted comment or for
aligning an existing comment. Major modes set this variable
differently. The function is called with no arguments, but with point
at the beginning of the comment, or at the end of a line if a new
comment is to be inserted. The function should return the column in
which the comment ought to start. For example, in Lisp mode, the
indent hook function bases its decision on the number of semicolons
that begin an existing comment and on the code in the preceding lines.
File: xemacs.info, Node: Balanced Editing, Next: Lisp Completion, Prev: Comments, Up: Programs
Editing Without Unbalanced Parentheses
======================================
`M-('
Put parentheses around next sexp(s) (`insert-parentheses').
`M-)'
Move past next close parenthesis and re-indent
(`move-over-close-and-reindent').
The commands `M-(' (`insert-parentheses') and `M-)'
(`move-over-close-
and-reindent') are designed to facilitate a style of editing which
keeps parentheses balanced at all times. `M-(' inserts a pair of
parentheses, either together as in `()', or, if given an argument,
around the next several sexps, and leaves point after the open
parenthesis. Instead of typing `( F O O )', you can type `M-( F O O',
which has the same effect except for leaving the cursor before the
close parenthesis. You can then type `M-)', which moves past the close
parenthesis, deletes any indentation preceding it (in this example
there is none), and indents with <LFD> after it.
File: xemacs.info, Node: Lisp Completion, Next: Documentation, Prev: Balanced Editing, Up: Programs
Completion for Lisp Symbols
===========================
Completion usually happens in the minibuffer. An exception is
completion for Lisp symbol names, which is available in all buffers.
The command `M-<TAB>' (`lisp-complete-symbol') takes the partial
Lisp symbol before point to be an abbreviation, and compares it against
all non-trivial Lisp symbols currently known to Emacs. Any additional
characters that they all have in common are inserted at point.
Non-trivial symbols are those that have function definitions, values, or
properties.
If there is an open-parenthesis immediately before the beginning of
the partial symbol, only symbols with function definitions are
considered as completions.
If the partial name in the buffer has more than one possible
completion and they have no additional characters in common, a list of
all possible completions is displayed in another window.
File: xemacs.info, Node: Documentation, Next: Change Log, Prev: Lisp Completion, Up: Programs
Documentation Commands
======================
As you edit Lisp code to be run in Emacs, you can use the commands
`C-h f' (`describe-function') and `C-h v' (`describe-variable') to
print documentation of functions and variables you want to call. These
commands use the minibuffer to read the name of a function or variable
to document, and display the documentation in a window.
For extra convenience, these commands provide default arguments
based on the code in the neighborhood of point. `C-h f' sets the
default to the function called in the innermost list containing point.
`C-h v' uses the symbol name around or adjacent to point as its default.
The `M-x manual-entry' command gives you access to documentation on
Unix commands, system calls, and libraries. The command reads a topic
as an argument, and displays the Unix manual page for that topic.
`manual-entry' always searches all 8 sections of the manual and
concatenates all the entries it finds. For example, the topic
`termcap' finds the description of the termcap library from section 3,
followed by the description of the termcap data base from section 5.
File: xemacs.info, Node: Change Log, Next: Tags, Prev: Documentation, Up: Programs
Change Logs
===========
The Emacs command `M-x add-change-log-entry' helps you keep a record
of when and why you have changed a program. It assumes that you have a
file in which you write a chronological sequence of entries describing
individual changes. The default is to store the change entries in a
file called `ChangeLog' in the same directory as the file you are
editing. The same `ChangeLog' file therefore records changes for all
the files in a directory.
A change log entry starts with a header line that contains your name
and the current date. Except for these header lines, every line in the
change log starts with a tab. One entry can describe several changes;
each change starts with a line starting with a tab and a star. `M-x
add-change-log-entry' visits the change log file and creates a new entry
unless the most recent entry is for today's date and your name. In
either case, it adds a new line to start the description of another
change just after the header line of the entry. When `M-x
add-change-log-entry' is finished, all is prepared for you to edit in
the description of what you changed and how. You must then save the
change log file yourself.
The change log file is always visited in Indented Text mode, which
means that <LFD> and auto-filling indent each new line like the previous
line. This is convenient for entering the contents of an entry, which
must be indented. *Note Text Mode::.
Here is an example of the formatting conventions used in the change
log for Emacs:
Wed Jun 26 19:29:32 1985 Richard M. Stallman (rms at mit-prep)
* xdisp.c (try_window_id):
If C-k is done at end of next-to-last line,
this fn updates window_end_vpos and cannot leave
window_end_pos nonnegative (it is zero, in fact).
If display is preempted before lines are output,
this is inconsistent. Fix by setting
blank_end_of_window to nonzero.
Tue Jun 25 05:25:33 1985 Richard M. Stallman (rms at mit-prep)
* cmds.c (Fnewline):
Call the auto fill hook if appropriate.
* xdisp.c (try_window_id):
If point is found by compute_motion after xp, record that
permanently. If display_text_line sets point position wrong
(case where line is killed, point is at eob and that line is
not displayed), set it again in final compute_motion.
File: xemacs.info, Node: Tags, Next: Fortran, Prev: Change Log, Up: Programs
Tags Tables
===========
A "tags table" is a description of how a multi-file program is
broken up into files. It lists the names of the component files and the
names and positions of the functions (or other named subunits) in each
file. Grouping the related files makes it possible to search or replace
through all the files with one command. Recording the function names
and positions makes possible the `M-.' command which finds the
definition of a function by looking up which of the files it is in.
Tags tables are stored in files called "tags table files". The
conventional name for a tags table file is `TAGS'.
Each entry in the tags table records the name of one tag, the name
of the file that the tag is defined in (implicitly), and the position
in that file of the tag's definition.
Just what names from the described files are recorded in the tags
table depends on the programming language of the described file. They
normally include all functions and subroutines, and may also include
global variables, data types, and anything else convenient. Each name
recorded is called a "tag".
* Menu:
* Tag Syntax:: Tag syntax for various types of code and text files.
* Create Tags Table:: Creating a tags table with `etags'.
* Select Tags Table:: How to visit a tags table.
* Find Tag:: Commands to find the definition of a specific tag.
* Tags Search:: Using a tags table for searching and replacing.
* List Tags:: Listing and finding tags defined in a file.
File: xemacs.info, Node: Tag Syntax, Next: Create Tags Table, Up: Tags
Source File Tag Syntax
----------------------
Here is how tag syntax is defined for the most popular languages:
* In C code, any C function or typedef is a tag, and so are
definitions of `struct', `union' and `enum'. `#define' macro
definitions and `enum' constants are also tags, unless you specify
`--no-defines' when making the tags table. Similarly, global
variables are tags, unless you specify `--no-globals'. Use of
`--no-globals' and `--no-defines' can make the tags table file
much smaller.
* In C++ code, in addition to all the tag constructs of C code,
member functions are also recognized, and optionally member
variables if you use the `--members' option. Tags for variables
and functions in classes are named `CLASS::VARIABLE' and
`CLASS::FUNCTION'.
* In Java code, tags include all the constructs recognized in C++,
plus the `extends' and `implements' constructs. Tags for variables
and functions in classes are named `CLASS.VARIABLE' and
`CLASS.FUNCTION'.
* In LaTeX text, the argument of any of the commands `\chapter',
`\section', `\subsection', `\subsubsection', `\eqno', `\label',
`\ref', `\cite', `\bibitem', `\part', `\appendix', `\entry', or
`\index', is a tag.
Other commands can make tags as well, if you specify them in the
environment variable `TEXTAGS' before invoking `etags'. The value
of this environment variable should be a colon-separated list of
commands names. For example,
TEXTAGS="def:newcommand:newenvironment"
export TEXTAGS
specifies (using Bourne shell syntax) that the commands `\def',
`\newcommand' and `\newenvironment' also define tags.
* In Lisp code, any function defined with `defun', any variable
defined with `defvar' or `defconst', and in general the first
argument of any expression that starts with `(def' in column zero,
is a tag.
* In Scheme code, tags include anything defined with `def' or with a
construct whose name starts with `def'. They also include
variables set with `set!' at top level in the file.
Several other languages are also supported:
* In assembler code, labels appearing at the beginning of a line,
followed by a colon, are tags.
* In Bison or Yacc input files, each rule defines as a tag the
nonterminal it constructs. The portions of the file that contain
C code are parsed as C code.
* In Cobol code, paragraphs names are the tags, i.e. any word
starting in column 8 and followed by a full stop.
* In Erlang code, the tags are the functions, records, and macros
defined in the file.
* In Fortran code, functions and subroutines are tags.
* In Objective C code, tags include Objective C definitions for
classes, class categories, methods and protocols.
* In Pascal code, the tags are the functions and procedures defined
in the file.
* In Perl code, the tags are the procedures defined by the `sub'
keyword.
* In Postscript code, the tags are the functions.
* In Prolog code, a tag name appears at the left margin.
You can also generate tags based on regexp matching (*note Create
Tags Table::.) to handle other formats and languages.
File: xemacs.info, Node: Create Tags Table, Next: Select Tags Table, Prev: Tag Syntax, Up: Tags
Creating Tags Tables
--------------------
The `etags' program is used to create a tags table file. It knows
the syntax of several languages, as described in *Note Tag Syntax::.
Here is how to run `etags':
etags INPUTFILES...
The `etags' program reads the specified files, and writes a tags table
named `TAGS' in the current working directory. `etags' recognizes the
language used in an input file based on its file name and contents.
You can specify the language with the `--language=NAME' option,
described below.
If the tags table data become outdated due to changes in the files
described in the table, the way to update the tags table is the same
way it was made in the first place. It is not necessary to do this
often.
If the tags table fails to record a tag, or records it for the wrong
file, then Emacs cannot possibly find its definition. However, if the
position recorded in the tags table becomes a little bit wrong (due to
some editing in the file that the tag definition is in), the only
consequence is a slight delay in finding the tag. Even if the stored
position is very wrong, Emacs will still find the tag, but it must
search the entire file for it.
So you should update a tags table when you define new tags that you
want to have listed, or when you move tag definitions from one file to
another, or when changes become substantial. Normally there is no need
to update the tags table after each edit, or even every day.
One tags table can effectively include another. Specify the included
tags file name with the `--include=FILE' option when creating the file
that is to include it. The latter file then acts as if it contained
all the files specified in the included file, as well as the files it
directly contains.
If you specify the source files with relative file names when you run
`etags', the tags file will contain file names relative to the
directory where the tags file was initially written. This way, you can
move an entire directory tree containing both the tags file and the
source files, and the tags file will still refer correctly to the source
files.
If you specify absolute file names as arguments to `etags', then the
tags file will contain absolute file names. This way, the tags file
will still refer to the same files even if you move it, as long as the
source files remain in the same place. Absolute file names start with
`/', or with `DEVICE:/' on MS-DOS and Windows.
When you want to make a tags table from a great number of files, you
may have problems listing them on the command line, because some systems
have a limit on its length. The simplest way to circumvent this limit
is to tell `etags' to read the file names from its standard input, by
typing a dash in place of the file names, like this:
find . -name "*.[chCH]" -print | etags -
Use the option `--language=NAME' to specify the language explicitly.
You can intermix these options with file names; each one applies to
the file names that follow it. Specify `--language=auto' to tell
`etags' to resume guessing the language from the file names and file
contents. Specify `--language=none' to turn off language-specific
processing entirely; then `etags' recognizes tags by regexp matching
alone. `etags --help' prints the list of the languages `etags' knows,
and the file name rules for guessing the language.
The `--regex' option provides a general way of recognizing tags
based on regexp matching. You can freely intermix it with file names.
Each `--regex' option adds to the preceding ones, and applies only to
the following files. The syntax is:
--regex=/TAGREGEXP[/NAMEREGEXP]/
where TAGREGEXP is used to match the lines to tag. It is always
anchored, that is, it behaves as if preceded by `^'. If you want to
account for indentation, just match any initial number of blanks by
beginning your regular expression with `[ \t]*'. In the regular
expressions, `\' quotes the next character, and `\t' stands for the tab
character. Note that `etags' does not handle the other C escape
sequences for special characters.
The syntax of regular expressions in `etags' is the same as in
Emacs, augmented with the "interval operator", which works as in `grep'
and `ed'. The syntax of an interval operator is `\{M,N\}', and its
meaning is to match the preceding expression at least M times and up to
N times.
You should not match more characters with TAGREGEXP than that needed
to recognize what you want to tag. If the match is such that more
characters than needed are unavoidably matched by TAGREGEXP, you may
find useful to add a NAMEREGEXP, in order to narrow the tag scope. You
can find some examples below.
The `-R' option deletes all the regexps defined with `--regex'
options. It applies to the file names following it, as you can see
from the following example:
etags --regex=/REG1/ voo.doo --regex=/REG2/ \
bar.ber -R --lang=lisp los.er
Here `etags' chooses the parsing language for `voo.doo' and `bar.ber'
according to their contents. `etags' also uses REG1 to recognize
additional tags in `voo.doo', and both REG1 and REG2 to recognize
additional tags in `bar.ber'. `etags' uses the Lisp tags rules, and no
regexp matching, to recognize tags in `los.er'.
Here are some more examples. The regexps are quoted to protect them
from shell interpretation.
Tag the `DEFVAR' macros in the emacs source files:
--regex='/[ \t]*DEFVAR_[A-Z_ \t(]+"\([^"]+\)"/'
Tag VHDL files (this example is a single long line, broken here for
formatting reasons):
--language=none
--regex='/[ \t]*\(ARCHITECTURE\|CONFIGURATION\) +[^ ]* +OF/'
--regex='/[ \t]*\(ATTRIBUTE\|ENTITY\|FUNCTION\|PACKAGE\
\( BODY\)?\|PROCEDURE\|PROCESS\|TYPE\)[ \t]+\([^ \t(]+\)/\3/'
Tag TCL files (this last example shows the usage of a NAMEREGEXP):
--lang=none --regex='/proc[ \t]+\([^ \t]+\)/\1/'
For a list of the other available `etags' options, execute `etags
--help'.